COM20020
ULANC
Universal Local Area Network Controller
with 2K x 8 On-Board RAM

### TABLE OF CONTENTS

| E        |                     | 1                 |                              |                      |                  |                                |                    |                           |               |             |                           |                              |                              |                          |                                   |                        |                |                    |             |                          |                |                    |                         |                   |                  |                  |                           | ()                       | 1       | Í                    |               |                                              |            |                    |                             |                    |                 |
|----------|---------------------|-------------------|------------------------------|----------------------|------------------|--------------------------------|--------------------|---------------------------|---------------|-------------|---------------------------|------------------------------|------------------------------|--------------------------|-----------------------------------|------------------------|----------------|--------------------|-------------|--------------------------|----------------|--------------------|-------------------------|-------------------|------------------|------------------|---------------------------|--------------------------|---------|----------------------|---------------|----------------------------------------------|------------|--------------------|-----------------------------|--------------------|-----------------|
| :        |                     | 7                 | ω.                           | 9                    | 9                | 9                              |                    | . 7                       | ∞:            | <u>ნ</u>    | 6                         | 12                           | 12                           | 4                        | 7                                 | 16                     | 16             | 17                 | 26          | 27                       | 28             | 28                 | 28                      | 29                | 29               | 32               | 32                        | 33                       | 34      | 35                   | 35            | က္ခ                                          | 36         | 37                 | ς<br>Υ                      | 38                 | 4               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| ċ        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | .:                        | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | :                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | Ē                        | :                                 | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | :                            | :                            | atic                     |                                   | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | :                         | :                        | :       | :                    | :             | :                                            | :          | :                  | :                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | :                              | :                  | :                         | :             | :           | :                         | ш.                           | Traditional Hybrid Interface | Open Drain Configuration | Differential Driver Configuration | :                      | :              | :                  | :           | :                        | :              | :                  | :                       | :                 | :                | :                | Transmit Command Chaining |                          | :       | :                    | :             | :                                            | :          | Ξ,                 |                             | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | •                              | :                  | z                         | :             | :           | щ                         | Ş                            | Face                         | S                        | gur                               | :                      | :              | :                  | :           | ρ٥                       | :              | :                  | 9                       | :                 | :                | :                | ij                        | Ē                        | :       | :                    | :             | :                                            | :          |                    | Ž                           | :                  | :               |
| :        | :                   | :                 | :                            | :                    | :                | S                              | :                  | 은                         | :             | :           | FAC                       | 뚪                            | iter                         | ij                       | out                               | :                      | :              | :                  | :           | Men                      | :              | :                  | Š                       | :                 | :                | :                | ຮັ                        | 훒                        | :       | :                    | :             | :                                            | :          | : !                | ₹                           | :                  | :               |
| :        | :                   | :                 | S                            | :                    | :                | ¥                              | s                  | 일                         | :             | :           | E                         | Z                            | <u>-</u>                     | ۵                        | Š                                 | :                      | :              | :                  | :           | SS                       | :              | ٠                  | age                     | ç                 | e,               | :                | and                       | ē                        | :       | ğ                    | U c           | 'n                                           | :          | : 6                | ב                           | :                  | :               |
| :        | :                   | :                 | ₫                            | :                    | ᅺ                | ä                              | B                  | ፫                         | :             | :           | Ξ                         | ĕ                            | ybi                          | be.                      | Š                                 | :                      | :              | s.                 | :           | S                        | 9              | S                  | Σ                       | jue.              | ĕ                | g                | Ĕ                         | Ē                        | :       | ĭ                    | E E           | <u>ۃ</u>                                     | :          | : }                | 1                           | က                  | :               |
| :        | :                   | :                 | 힞                            | _                    | ö                | Ĕ                              | SS                 | 5                         | :             | :           | 띮                         | 핗                            | ᆵ                            | 0                        | jaj [                             | ž                      | Æ.             | 띮                  | :           | <u>ه</u>                 | bee            | Æ                  | ≨                       | Š                 | ğ                | 를                | ខិ                        | 点                        | :       | ese                  | SEQUENCE      | ğ                                            |            | 8                  | 2                           | Ĕ                  | NS.             |
| :        | z                   | :                 | Ξ                            | ₫                    | õ                | S                              | ¥                  | ¥                         | 엉             | Z           | ᅙ                         | ž                            | ij                           | gan                      | ent                               | Ĕ                      | ᅙ              | GIS                | Σ           | anti                     | ss S           | 빍                  | ting                    | ij                | ě                | ₹                | ij                        | ě                        | က       | ᅙ                    | Ž.            | 5                                            | :          | <u>E</u> :         | ¥                           |                    | ₹               |
| :        | Ĕ                   | 8                 | 몶                            | 噕                    | NETWORK PROTOCOL | <b>NETWORK RECONFIGURATION</b> | BROADCAST MESSAGES | EXTENDED TIMEOUT FUNCTION | LINE PROTOCOL | DESCRIPTION | MICROCONTROLLER INTERFACE | TRANSMISSION MEDIA INTERFACE | radi                         | Backplane                | iffe                              | 8                      | MICROSEQUENCER | INTERNAL REGISTERS | NTERNAL RAM | Sequential Access Memory | Access Speed . | SOFTWARE INTERFACE | Selecting RAM Page Size | Transmit Sequence | Receive Sequence | COMMAND CHAINING | rans                      | Receive Command Chaining | DETAILS | Internal Reset Logic | NITIALIZATION | MPROVED DIAGNOSTICS                          | 5          | <u>წ</u>           | MAXIMUM GUARANI EED KATINGS | OC CHARACTERISTICS | LIMING DIAGRAMS |
| :        | 8                   | Ξ¥                | 9                            | SS                   | 8                | 8                              | Š                  | 필                         | õ             | 붉           | 8                         | SMI                          | _                            | ∞                        | Ω                                 | ES                     | SE(            | ₹                  | ₹           | S                        | ⋖              | Ϋ́                 | S                       | _                 | œ                | ₹                | F                         |                          |         | 드                    | 12            | ֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֓֟֝֓֓֓֓֓֓ | DSCILLATOR |                    | ٍ إ                         | ₹.                 | <u> </u>        |
| :        | SES                 | 3CF               | 8                            | ä                    | }                | ⋛                              | ğ                  | É                         | 빌             | SS          | 뚪                         | Š                            |                              |                          |                                   | 4                      | £              | 띮                  | 띮           |                          |                | Ē                  |                         |                   |                  | Š                |                           |                          | RESET   |                      | ጀጀ            | 5                                            | ₹:         | 4                  | \$                          | ₽                  | ž               |
| ű        | 7                   | Ĭ                 | Ĕ                            | 힍                    | Z                | 岁                              | 8                  | Ж                         |               | 0           | Σ                         | E                            |                              |                          |                                   | Š                      | Ξ              | Z                  | Z           |                          |                | S                  |                         |                   |                  | ပ                |                           |                          | ä       |                      | Ž.            | Σ                                            | So         | TIONAL DESCRIPTION | È                           | 2                  | É               |
| EAL ORES | GENERAL DESCRIPTION | PIN CONFIGURATION | DESCRIPTION OF PIN FUNCTIONS | PROTOCOL DESCRIPTION |                  |                                |                    |                           |               | SYSTEM      |                           |                              |                              |                          |                                   | S                      |                |                    |             |                          |                |                    |                         |                   |                  |                  |                           |                          |         |                      |               |                                              | - :        | RAI                |                             |                    |                 |
| 4        | GEN                 | 짇                 | DES                          | PRO                  |                  |                                |                    |                           |               | SYS         |                           |                              |                              |                          |                                   | FUNCTIONAL DESCRIPTION |                |                    |             |                          |                |                    |                         |                   |                  |                  |                           |                          |         |                      |               |                                              |            | OPERA              |                             |                    |                 |
|          |                     |                   | _                            |                      |                  |                                |                    |                           |               | -           |                           |                              |                              |                          |                                   |                        |                |                    |             |                          |                |                    |                         |                   |                  |                  |                           |                          |         |                      |               |                                              | ,          | _                  |                             |                    |                 |

For more details on the ARCNET protocol and traditional dipulse signaling schemes, please refer to the <u>ARCNET Local Area Network Standard</u>, available from Standard Microsystems Corporation or the ARCNET Designer's Handbook, available from Datapoint Corporation.

For more detailed information on cabling options including RS485, transformer-coupled RS-485 and Fiber Optic Interfaces, please refer to the following technical note which is available from Standard Microsystems Corporation: Technical Note 7-5 - Cabling Guidelines for the COM20020 ULANC.

#### STANDARD MICROSYSTEMS PRODUCTS DIVISION 35 Marcus Bhd., Hauppauge, NY 11788 1516) 273-3100 Fax (516) 231-6004

### COM20020

# Universál Local Area Network Controller COM20020 ULANC

### 24-Pin DIP or 28-Pin PLCC Package **FEATURES**

with 2K x 8 On-Board RAM

- 24-Pin ARCNET® Controller/Transceiver/
  - Ideal for Industrial/Factory Automation **Dual-Port RAM** 
    - and Automotive Applications
- Deterministic, 2.5 Mbps, Token Passing Protocol
  - Minimal Microcontroller and Media

Backplane Mode for Direct Connection to

Low Cost, Low Power, High Reliability RS485 Differential Driver Interface for

- Traditional Hybrid Interface for Long

Flexible Media Interface:

Eight, 256-Byte Pages Allow 4 Pages TX

and RX Plus Temporary Storage and

Internal Clock Prescaler for Slower Network Speed without Slowing

No Wait-State Arbitration

Scratch-Pad Memory

Media in Short Distance Applications

- Flexible Microcontroller Interface for Interfaces
  - Automatically Detects Type of Use with 80XX, 68XX, etc.
- Non-Multiplexed or Multiplexed Bus Microcontroller Interface:
- Separate RD & WR Lines or DIR & DS
- Full 2Kx8 On-Chip Dual-Port RAM Command Chaining for Top

Operating Temperature Range of -40°C to

Arbitration

Supports Various Network Topologies

CMOS, Single +5V Supply

(Star, Tree, Bus...)

Self-Reconfiguration Protocol Supports up to 255 Nodes

+85°C, or 0°C to +70°C

- Sequential Access to Internal RAM Performance
  - Software Programmable Node ID
    - **Duplicate Node ID Detection**
- Powerful Diagnostics

GENERAL DESCRIPTION SMC's COM20020 is a member of the family of ULANCs from Standard Microsystems Corporation. The device is a special purpose communications controller for networking microcontrollers and intelligent peripherals in industrial and automotive settings using the and media interfaces, eight-page message optimized for use in industrial and automotive factory automation applications because it reliable and proven networking scheme, and a small 24-pin package, flexible microcontroller support, and industrial temperature range of the applications. ARCNET is the ideal solution for COM20020 make it the only ARCNET Controller provides a token-passing protocol, a highly ARCNET Local Area Network protocol. lata rate of 2.5 Mbps.

response times because each network event based upon the number of nodes on the occurs within a predetermined time interval, network. The deterministic nature of ARCNET A token-passing protocol provides predictable is essential in mission critical applications. The integration of the 2Kx8 RAM buffer onchip, the Command Chaining feature, the 2.5 Mbps data rate, and the internal diagnostics nake the COM20020 the highest performance With only one COM20020 and one microcontroller, a complete ARCNET node may industrial communications device available. be implemented. ARCNET is a registered trademark of Datapoint Corporation



# **DESCRIPTION OF PIN FUNCTIONS**

| DIP PIN<br>NO. | PLCC PIN<br>NO. | NAME                | SYMBOL                    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|-----------------|---------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                 | MICRO               | MICROCONTROLLER INTERFACE | INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1-3            | 5-1-3           | Address<br>0-2*     | AO/MUX,<br>A1,A2/ALE      | linput. On a non-multiplexed bus, these signals are directly connected to the low bits of the host address bus. On a multiplexed address/data bus, AO/MUX is tied low, A1 is left open, and A2 is tied to the Address Latch Enable signal of the host. A1 is connected to an internal pullup resistor.                                                                                                                                                                                                                                                                  |
| 4-11           | 4-6,8-12        | Data 0-7            | AD0-AD2,<br>D3-D7         | Input/Output. On a non-multiplexed bus, these signals are used as the data lines for the device. On a multiplexed address/data bus, ADO-AD2 act as the address lines for the device. D3-D7 are always used for data only. These signals are connected to internal pull-up resistors.                                                                                                                                                                                                                                                                                    |
| 23             | 27              | Read/Data Strobe    | <u>ਜਹ/ਹ§</u>              | lingut. On a 68XX-like bus, this active low signal is issued by the microcontroller as the data strobe signal to strobe the data onto the bus. On a 8OXX-like bus, this active low signal is issued by the microcontroller to indicate a read operation. In this case, a logic "O" on this pin, when the COM20020 is accessed, enables data from the device to the data bus to be read by the microcontroller.                                                                                                                                                          |
| 22             | 26              | Write/<br>Direction | WR/DIR                    | issued by the microcontroller as the Read/Write signal to determine the direction of data transfer. In this case, a logic "0" selects a read operation, while a logic "0" selects a verte operation, while a logic "0" selects a write operation. In this case, data is actually strobed by the \$\overline{DS}\$ signal. On an 80XX-like bus, this active low signal is issued by the microcontroller to indicate a write operation. In this case, a logic "0" on this pin, when the COM20020 is accessed, enables data from the data bus to be written to the device. |

က

THE REPORT OF THE PROPERTY OF

# DESCRIPTION OF PIN FUNCTIONS

|                 | l by the e reset.                                                                                                                                               | signal is when an urs. INTR when the or the is reset.                                                                                                                                                                            | l by the<br>020 for                                                                             |                              | wation, mation, m the riccuitry. de, the driver, a clock SET is                                                                                                                                                                                                                                                                                           | ve data<br>circuitry                                                                                      | drivers                                                                                               |               | scted to<br>slock is<br>sted to<br>or, and                                                                                                                                                              |                           |             |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------|
| DESCRIPTION     | Input. This active low signal issued by the microcontroller executes a hardware reset. It is used to activate the internal reset circuitry within the COM20020. | Output. This active low signal is generated by the COM20020 when an enabled interrupt condition occurs. INTR returns to its inactive state when the interrupt status condition or the corresponding interrupt mask bit is reset. | Input. This active low signal issued by the microcontroller selects the COM20020 for an access. | TRANSMISSION MEDIA INTERFACE | Output. In Normal Mode, these active low signals carry the transmit data information, encoded in pulse format, from the COM20020 to the media driver circuitry. When the device is in Backplane Mode, the PULSE1 signal is an open-drain driver, while frequency of crystal/4. PULSE1 is connected to a weak internal pull-up resistor in backplane mode. | Input. This signal carries the receive data information from the line receiver circuitry to the COM20020. | Output. This active low signal is used in Backplane Mode to enable the line drivers for transmission. | sons          | An external crystal should be connected to these pins. If an external TTL clock is used instead, it must be connected to XTAL1 with a 390 $\Omega$ pull-up resistor, and XTAL2 should be left floating. | +5 Volt Power Supply pin. | Ground pin. |
| SYMBOL          | RESET IN                                                                                                                                                        | INTR                                                                                                                                                                                                                             | <u>so</u>                                                                                       | MISSION MED                  | PULSE7,                                                                                                                                                                                                                                                                                                                                                   | RXIN                                                                                                      | TXEN                                                                                                  | MISCELLANEOUS | XTAL1,<br>XTAL2                                                                                                                                                                                         | V <sub>DD</sub>           | Vss         |
| NAME            | Reset in                                                                                                                                                        | Interrupt                                                                                                                                                                                                                        | Chip Select                                                                                     | TRANS                        | Pulse Z,<br>Pulse 1                                                                                                                                                                                                                                                                                                                                       | Receive In                                                                                                | Transmit<br>Enable                                                                                    |               | Crystal<br>Oscillator                                                                                                                                                                                   | Power<br>Supply           | Ground      |
| PLCC PIN<br>NO. | 23                                                                                                                                                              | 24                                                                                                                                                                                                                               | 25                                                                                              |                              | 19,18                                                                                                                                                                                                                                                                                                                                                     | 20                                                                                                        | 21                                                                                                    |               | 16,17                                                                                                                                                                                                   | 15,28                     | 7,14,22     |
| DIP PIN<br>NO.  | 19                                                                                                                                                              | 20                                                                                                                                                                                                                               | 21                                                                                              |                              | 16, 15                                                                                                                                                                                                                                                                                                                                                    | 17                                                                                                        | 18                                                                                                    |               | 13,14                                                                                                                                                                                                   | 24                        | 12          |



# PROTOCOL DESCRIPTION

### NETWORK PROTOCOL

and the transmitter passes the token. Once it selected status bits become true. Figure 1 is a Communication on the network is based on a data by simply loading a data packet and its destination ID into the COM20020's RAM receives the token, it verifies that the receiving node is ready by first transmitting a FREE packet (typically its receiver is inhibited), it can accept the packet and transmission is nterrupt mask permits the COM20020 to generate an interrupt to the processor when buffer, and issuing a command to enable the transmitter. When the COM20020 next data packet is transmitted followed by a 16-bit CRC. If the receiving node cannot accept the has been established that the receiving node successfully) allowing the transmitter to set the oken passing protocol. Establishment of the network configuration and management of the network protocol are handled entirely by the A processor or intelligent peripheral transmits BUFFER ENQUIRY message. If the receiving node transmits an ACKnowledge message, the transmits a Negative AcKnowledge message complete, the receiving node verifies the packet. If the packet is received successfully, the receiving node transmits an ACKnowledge message (or nothing if it is not received appropriate status bits to indicate successful or low chart illustrating the internal operation of COM20020's internal microcoded sequencer. unsuccessful delivery of the packet. he COM20020.

# **NETWORK RECONFIGURATION**

A significant advantage of the COM20020 is its ability to adapt to changes on the network. Whenever a new node is activated or deactivated, a NETWORK RECONFIGURATION is performed. When a new COM20020 is turned on (creating a new active node on the

an INVITATION TO TRANSMIT for 840mS, or if a software reset occurs, the COMZ0020 causes a NETWORK RECONFIGURATION by sending a NETWORK RECONFIGURATION by sending a RECONFIGURE BURST consisting of eight marks and one space repeated 765 times. The purpose of this burst is to terminate all activity on the network. Since this burst is longer than any other type of transmission, the burst will interfere with the next INVITATION TO ITANSMIT, destroy the token and keep any other node from assuming control of the line.

possible ID node) equal to its own ID. If the timeout expires with no line activity, the COM20020 waits for activity on the line. If there is no activity for  $74.7\mu S$ , the COM20020 When any COM20020 senses an idle line for greater than  $82\mu S$ , which occurs only when the timeout equal to 146µs times the quantity 255 minus its own ID. It also sets the internally stored NID (next ID representing the next COM20020 starts sending INVITATION TO TRANSMIT with the Destination ID (DID) equal to the currently stored NID. Within a given network, only one COM20020 will timeout (the one with the highest ID number). After sending the INVITATION TO TRANSMIT, the increments the NID value and transmits another NVITATION TO TRANSMIT using the NID equal  $^{14.7}\mu S$  timeout expires, the COM20020 RECONFIGURATION, INVITATIONS TO token is lost, each COM20020 starts an internal to the DID. If activity appears before the releases control of the line. During NETWORK **IRANSMIT** are sent to all NIDs.

Each COM20020 on the network will finally have saved a NID value equal to the ID of the COM20020 that it released control to. At this point, control is passed directly from one node to the next with no wasted INVITATIONS TO TANSMIT being sent to ID's not on the nextwork, until the next NETWORK

RECONFIGURATION occurs. When a node is powered off, the previous node attempts to pass the token to it by issuing an INVITATION TO TRANSMIT. Since this node does not respond, the previous node times out and transmits another INVITATIOM TO TRANSMIT to an incremented ID and eventually a response will be received.

The NETWORK RECONFIGURATION time depends on the number of nodes in the network, the propagation delay between nodes, and the highest ID number on the network, but is typically within the range of 24 to 61 ms.

### SROADCAST MESSAGES

Broadcasting gives a particular node the ability to transmit a data packet to all nodes on the network simultaneously. ID zero is reserved for this feature and no node on the network can be assigned ID zero. To broadcast a message, the transmitting node's processor simply loads the RAM buffer with the data packet and sets the DID equal to zero. Figure 7 illustrates the position of each byte in the packet with the DID residing at address 1H of the current page selected in the Enable Transmit from Page fnn command. Each individual node has the ability to ignore broadcast messages by setting the most significant bit of the "Enable Receive to Page fnn" command (see Table 6) to a logic "O".

# EXTENDED TIMEOUT FUNCTION

There are three timeouts associated with the COM20020 operation. The values of these timeouts are controlled by bits 3 and 4 of the Configuration Register.

#### Response Time

The Response Time determines the maximum propagation delay allowed between any two nodes, and should be chosen to be larger than

and the second of the second of the second

with an Alexander which the Manusco with a secondary of the endounce to the second to the

the round trip propagation delay between the two furthest nodes on the network plus the maximum turn around time (the time it takes a particular COM20020 to start sending a message in response to a received message) which is approximately 12.7µS. The round trip propagation delay is a function of the transmission media and network topology. For a typical system, aone way cable propagation delay of 31µS translates to a distance of about 4 miles. The flow chart in Figure 1 uses a value of 74.7µS (31 + 31 + 12.7) to determine if any node will respond.

#### dle Time

The Idle Time is associated with a NETWORK RECONFIGURATION. Figure 1 illustrates that during a NETWORK RECONFIGURATION one node will continually transmit INVITATIONS TO TRANSMIT until it encounters an active node. All other nodes on the network must distinguish between this operation and an entirely idle line. During NETWORK RECONFIGURATION, activity will appear on the line every 82µS. This 82µS is equal to the Response Time of 74.7µS plus the time it takes the COM20020 to start retransmitting another message (usually another INVITATION TO TRANSMIT).

### Reconfiguration Time

If any node does not receive the token within the Reconfiguration Time, the node will initiate a NETVORK RECONFIGURATION. The ET2 and ET1 bits of the Configuration Register allow the network to operate over longer distances than the 4 miles stated earlier. The logic levels on these bits control the maximum distances over which the COM20020 can operate by controlling the three timeout values described above. For proper network operation, all COM20020's connected to the same network must have the same Response Time, Idle Time, and Reconfiguration Time.

#### LINE PROTOCOL

is transmitted every 4.4µS and the time to The ARCNET line protocol is considered sochronous because each byte is preceded by constant amount of time separating each data intervals of 400ns each. As a result, one byte "0") condition. A logic "0" is defined as no line pulse of 200nS duration. A transmission starts characters are then sent, with each character preceded by 2 unit intervals of mark and one Unlike asynchronous protocols, there is a byte. Each byte takes exactly 11 clock transmit a message can be precisely determined. The line idles in a spacing (logic activity and a logic "1" is defined as a negative with an ALERT BURST consisting of 6 unit intervals of mark (logic "1"). Eight bit data transmission can be performed as described Five types of a start interval and ended with a stop interval unit interval of space.

### Invitations To Transmit

An Invitation To Transmit is used to pass the token from one node to another and is sent by the following sequence:

- An ALERT BURST
- An EOT (End Of Transmission: ASCII code 04H)
- Two (repeated) DID (Destination ID) characters

| QIQ            |
|----------------|
| QIQ            |
| EOT            |
| ALERT<br>BURST |

### Free Buffer Enquiries

node if it is able to accept a packet of data. It A Free Buffer Enquiry is used to ask another is sent by the following sequence:

- An ALERT An ENO (8
- Two (repo character

| 35H)<br>ID)                                                                                         | Qta            |
|-----------------------------------------------------------------------------------------------------|----------------|
| CII code Eestination                                                                                | QIQ            |
| JRST<br>tuiry: AS(<br>d) DID (D                                                                     | ENO            |
| n ALERT BURST<br>n ENQ (ENQuiry: ASCII code 85H)<br>wo (repeated) DID (Destination ID)<br>naracters | ALERT<br>BURST |

#### **Data Packets**

A Data Packet consists of the actual data being It is sent by the sent to another node. following sequence:

- An ALERT BURST
- An SOH (Start Of Header--ASCII code
- An SID (Source ID) character Two (repeated) DID (Destination ID)

01H)

- bytes to follow if a short packet is sent, or 00H followed by a COUNT character if a A single COUNT character which is the 2's complement of the number of data characters
- N data bytes where COUNT = 256-N (or 512-N for a long packet) long packet is sent
- characters. The CRC polynomial used is: Two CRC (Cyclic Redundancy Check)  $X^{16} + X^{15} + X^2 + 1$ .

The second determination the COM20020 makes is whether the bus is multiplexed or non-

ဗ္ဗ

S

data

data

NOO NOO

음

음

SID

SOH

BURST ALERT

### Acknowledgements

reception of a packet or as an affirmative response to FREE BUFFER ENQUIRIES and is An Acknowledgement is used to acknowledge sent by the following sequence:

A Negative Acknowledgement is used as a negative response to FREE BUFFER ENQUIRIES

Negative Acknowledgements

and is sent by the following sequence:

An ALERT BURST

A NAK (Negative Acknowledgement--ASCII

code 15H) character An ALERT BURST

> An ACK (ACKnowledgement--ASCII code 86H) character

|                | 1 |
|----------------|---|
| ACK            |   |
| ALERT<br>BURST |   |

| NAK   |       |
|-------|-------|
| ALERT | BURST |

### SYSTEM DESCRIPTION

# MICROCONTROLLER INTERFACE

The left halves of Figures 2 and 3 illustrate microcontrollers. The interfaces consist of an COM20020 automatically detects and adapts to 8-bit data bus, an address bus, and a control bus. In order to support a wide range of microcontrollers without requiring glue logic and without increasing the number of pins, the 2 the type of microcontroller being used. typical COM20020 interfaces

Upon hardware reset, the COM20020 first determines whether the read and write control signals are separate READ and WRITE signals (like the 80XX) or DIRECTION and DATA STROBE (like the 68XX). To determine the type of control signals, the device requires the software to execute at least one write access to external memory before attempting to access like signals. Once the type of control signals are determined, the COM20020 remains in this the COM20020. The device defaults to 80XXinterface mode until the next hardware reset

multiplexed. To determine the type of bus, the device requires the software to access an odd external memory location before attempting to access the COM20020. The AO bit of the odd access tells the COM20020 the type of bus. Since multiplexed operation requires A0 to be grounded, activity on the AO line tells the COM20020 that the bus is non-multiplexed. The device defaults to multiplexed operation. Both determinations may be made simultaneously by performing a single write to an odd external memory location. Once the type of bus is determined, the COM20020 remains in this interface mode until hardware reset occurs. Whenever CS is activated, the preset determinations are assumed as final and to Description of Pin Functions for details on will not be changed until hardware reset. Refer the related signals. All accesses to the internal RAM and the internal registers are controlled by the COM20020. The internal RAM is accessed via a pointer-based scheme (refer to the Sequential Access Memory section), and the internal registers are accessed via direct addressing. Take the second second

œ

and a standard of his bold of the bound of bolds on the bold of th





Ξ

Many peripherals are not fast enough to take advantage of high-speed microcontrollers. Since microcontrollers do not typically have READY inputs, standard peripherals cannot extend cycles to extend the access time. The access time of the COM20020, on the other hand, is so fast that it does not need to limit the speed of the microcontroller. The COM20020 is designed to be flexible so that it is independent of the microcontroller speed.

random accesses to the RAM. The data within placed into the data register for the microcontroller to read. During a write operation, the data is stored in the data register and then written into memory. Whenever the The COM20020 provides for no wait state arbitration via direct addressing to its internal registers and a pointer based addressing scheme to access its internal RAM. The pointer may be sequential buffer emptying or loading, or it can be taken out of auto-increment mode to perform Data being read is prefetched from memory and data is immediately prefetched to prepare for used in auto-increment mode for typical pointer is loaded for reads with a new value, the RAM is accessed through the data register. the first read operation.

# FRANSMISSION MEDIA INTERFACE

The right halves of Figures 2 and 3 illustrate the COM20020 interface to the transmission media used to connect the node to the network. Table 1 lists different types of cable which are suitable for ARCNET applications. The user

may interface to the cable of choice in one of three ways:

### Traditional Hybrid Interface

coupling of the Hybrid offers isolation for the dipulse signal on the media. A logic "O" is a positive pulse at the RXIN pin of the COM20020. The pulse on the RXIN pin represents a logic "1". Lack of pulse represents still correctly capture and convert the RXIN The Traditional Hybrid Interface is that which is Hybrid Interface is recommended if the node is safety of the system and offers high Common The Traditional Hybrid Interface uses circuits like SMC's HYC9068 or between the cable and the COM20020. The a logic "0". The PULSE1 and PULSE2 signals are sent to the Hybrid, which creates a 200nS on the media is coupled through the RF transformer of the LAN Driver, which produces a logic "O". Typically, RXIN pulses occur at The COM20020 can tolerate distortion of plus or minus 100nS and pulses to NRZ format. Figure 4 illustrates the events which occur in transmission or reception HYC9088 to transfer the pulse-encoded data two 100nS non-overlapping negative pulses, PULSE1 and PULSE2. Lack of pulses indicates transmitted by the absence of the dipulse. During reception, the 200nS dipulse appearing to be placed in a network with other Hybrid-Also, the transformer COM20020 transmits a logic "1" by generating used with previous ARCNET devices. of data consisting of 1, 1, 0. multiples of 400nS. Interfaced nodes. Mode Rejection.



<sup>1</sup> Please refer to TN7-5 - Cabling Guidelines for the COM20020 ULANC, available from SMC, for recommended cabling distance, termination, and node count for ARCNET nodes.

and the second of the second second second of the second s

# Backplane Open Drain Configuration

The Backplane Open Drain Configuration is recommended for cost-sensitive, short-distance applications like backplanes and nstrumentation. This mode is advantageous because it saves components, cost, and power.

Since the Backplane Configuration encodes data differently than the traditional Hybrid Configuration, nodes utilizing the Backplane Configuration cannot communicate directly with nodes utilizing the Traditional Hybrid Configuration.

The Backplane Configuration does not isolate the node from the media nor protect it from Common Mode noise, but Common Mode Noise is less of a problem in short distances.

The Backplane Configuration provides for direct connection between the COM20020 and the media. Only one pull-up resistor is required somewhere on the media (not on each individual node). The PULSET signal, in this mode, is an open drain driver and is used to directly drive the media. It issues a 200nS negative pulse to transmit a logic."1".

The PULSE1 signal actually contains a weak pull-up resistor. This pull-up should not take the place of the resistor required on the media. In typical applications, the serial backplane is terminated at both ends and a bias is provided by the external pull-up resistor.

The RXIN signal is directly connected to the cable via an internal Schmitt trigger. A negative pulse on this input indicates a logic "1". Lack of pulse indicates a logic "0". For typical single-ended backplane applications, RXIN is connected to PULSE1 to make the serial backplane data line. A ground line (from the coax or twisted pair) should run in parallel with

the signal. For applications requiring different treatment of the receive signal (like filtering or squelching), PULSE1 and RXIN remain as independent pins. External differential divers/receivers for increased range and common mode noise rejection, for example, would require the signals to be independent of one another. When the device is in Backplane Mode, the clock provided by the PULSE2 signal may be used for encoding the data into a different encoding scheme or other synchronous operations needed on the serial data stream.

# Differential Driver Configuration

The Differential Driver Configuration is a special case of the Backplane Mode. It is a dc coupled configuration recommended for applications like car-area networks or other cost-sensitive applications which do not require direct compatibility with existing ARCNET nodes and do not require isolation.

The Differential Driver Configuration cannot communicate directly with nodes utilizing the Traditional Hybrid Configuration. Like the Backplane Configuration, the Differential Driver Configuration does not isolate the node from the media.

The Differential Driver interface includes a RS485 Driver/Receiver to transfer the data between the cable and the COM20020. The PULSE1 signal transmits the data, provided the Transmit fable signal is active. The PULSE1 signal issues a 200nS negative pulse to transmit a logic "1". The RXIN signal receives the data. A negative pulse on this input indicates a logic "1". Lack of pulse indicates a logic "1". Lack of pulse indicates a logic "0". The transmitter portion of the COM20020 is disabled during reset and the PULSE1, PULSE2 and TXEN pins are inactive pinh



and the second of the control of the second of

Table 1 - Typical ARCNET Media

| NOMINAL |
|---------|
|         |
|         |
|         |
|         |
|         |
|         |

\*Non-plenum-rated cables of this type are also available.

Note: For more detailed information on Cabling options including RS-485, transformer-coupled RS-485 and Fiber Optic interfaces, please refer to TN7-5 - <u>Cabling Guidelines for the COM20020 ULANC</u>, available from Standard Microsystems Corporation.

# FUNCTIONAL DESCRIPTION

### MICROSEQUENCER

The COM20020 contains an internal microsequencer which performs all of the control operations necessary to carry out the ARCNET protocol. It consists of a clock generator, a 544 x 8 ROM, a program counter, two instruction registers, an instruction decoder, a no-op generator, jump logic, and reconfiguration logic.

The COM20020 derives a 5MHz and a 2.5MHz clock from the external crystal. These clocks provide the rate at which the instructions are executed within the COM20020. The 5MHz clock is the rate at which the program counter operates, while the 2.5MHz clock is the rate at which the instructions are executed. The microprogram is stored in the ROM and the

data. Once the instruction is fetched, it is which point the COM20020 proceeds to op code, while the other holds the immediate execute the instruction. When a no-op instruction is encountered, the microsequencer enters a timed loop and the program counter is the instruction registers. One register holds the decoded by the internal instruction decoder, at temporarily stopped until the loop is complete. When a jump instruction is encountered, the program counter is loaded with the jump address from the ROM. The COM20020 contains an internal reconfiguration timer which interrupts the microsequencer if it has timed At this point the program counter is cleared and the MYRECON bit of the Diagnostic instructions are fetched and then placed into Status Register is set.

# INTERNAL REGISTERS

The COM20020 contains eight internal registers. Tables 2 and 3 illustrate the COM20020 register map. Reserved locations should not be accessed. All undefined bits are read as undefined and must be written as logic

### Interrupt Mask Register (IMR)

The COM20020 is capable of generating an interrupt signal when certain status bits become true. A write to the IMR specifies which status bits will be enabled to generate an interrupt. The bit positions in the IMR are in the same position as their corresponding status bits in the Status Register and Diagnostic Status Begister. A logic "1" in a particular position enables the corresponding interrupt. The Status bits capable of generating an interrupt include the Receiver Inhibited bit, Excessive NAK bit, Reconfiguration Timer bit, and Transmitter Available bit. No other Status or Diagnostic Status bits can generate an interrupt.

The four maskable status bits are ANDed with their respective mask bits, and the results are ORed to produce the interrupt signal. A RI or TA interrupt is masked when the corresponding mask bit is reset to logic "O", but will reappear when the corresponding mask bit is set to logic "1" again, unless the interrupt status condition has been cleared by this time. A RECON interrupt is cleared when the "Clear Flags" command is issued. An EXCNAK interrupt is cleared when the "POR Clear Flags" command is issued. The Interrupt Mask Register defaults to the value 0000 0000 upon either hardware or software reset.

#### Oata Register

This read/write 8-bit register is used as the channel through which the data to and from the RAM passes. The data is placed in or retrieved from the address location presently specified by

the address pointer. The contents of the Data Register are undefined upon hardware reset.

### **Tentative ID Register**

are set up accordingly (please refer to the The Tentative ID Register can be used while the node is on-line to build a network map of those nodes existing on the network. It minimizes the need for operator interaction with the network. The node determines the existence of other nodes by placing a Node ID value in the Tentative ID Register and waiting to see if the Tentative ID The network map developed by this method is only valid for a short period of time, since nodes may join or depart from the network at any time. The Tentative ID Register defaults to The Tentative ID Register is a read/write 8-bit register accessed when the Sub Address Bits bit of the Diagnostic Status Register gets set. the value 0000 0000 upon hardware reset only. Configuration Register).

#### Node ID Register

register accessed when the Sub Address Bits are set up accordingly (please refer to the Configuration Register). The Node ID Register contains the unique value which identifies this section for further detail on the use of the DUPID bit. The core of the COM20020 does not wake up until a Node ID other than zero is The Node ID Register is a read/write 8-bit particular node. Each node on the network must occupy a unique Node ID value at all times. The Duplicate ID bit of the Diagnostic Status Register helps the user find a unique Node ID. Refer to the Initialization Sequence written into the Node ID Register. During this time, no microcode is executed, no tokens are are caused by this node. Once a non-zero Node wakes up but will not join the network until the TXEN bit of the Configuration Register is set. passed by this node, and no reconfigurations ID is placed into the Node ID Register, the core portion of the device is still functional and will While the Transmitter is disabled, the Receiver

and the second of the second o

many Shorter of the of sometimes of his Stock and the market will be sent to be

Table 2 - Read Register Summary

| -        |          |                 |                     |                    |      |          |                    |                             |
|----------|----------|-----------------|---------------------|--------------------|------|----------|--------------------|-----------------------------|
| •        |          |                 |                     |                    |      |          |                    |                             |
| ADDRESS  | 00       | 10              | 8                   | ន                  | 96   | 85       | 90                 | 20                          |
| LSB      | Δ.       | ×               | AB                  | ΑO                 | 8    | ×        | SUB-<br>AD0        | NIDO/<br>ARBSL              |
|          | TMA      | ×               | 98                  | P4                 | 5    | ×        | SUB-               | TID1/<br>NID1/<br>CKP1      |
|          | RECON    | TENTID          | A10                 | A2                 | D2   | ×        | BACK-<br>PLANE     | TID2/<br>NID2/<br>CKP2      |
|          | TEST     | EXCNAK TENTID   | ×                   | A3                 | 2    | ×        | ET2                | /SOIN<br>X<br>X             |
| READ     | POR      |                 | ×                   | <b>A4</b>          | 7    | ×        | E                  | NID4/                       |
|          | ×        | RCVACT TOKEN    | ×                   | A5                 | D2   | ×        | YEN                | TIDS/<br>NIDS/<br>X         |
|          | ×        | DUPID           | AUTO-<br>INC        | A6                 | 90   | ×        | CCHEN              | 71D6/<br>NID6/<br>X         |
| MSB      | <u>æ</u> | MYRECON DUPID   | нррата              | Α7                 | 20   | ×        | RESET              | // COIN<br>// COIN<br>X     |
| REGISTER | STATUS   | DIAG.<br>STATUS | ADDRESS<br>PTR HIGH | ADDRESS<br>PTR LOW | DATA | RESERVED | CONFIG-<br>URATION | TENTID/<br>NODEID/<br>SETUP |

| ADDRESS | MSB            |                     |                     | WRITE | ш                   |                        |               | RSI                     | REGISTER                    |
|---------|----------------|---------------------|---------------------|-------|---------------------|------------------------|---------------|-------------------------|-----------------------------|
| 8       | æ              | 0                   | 0                   | 0     | EXCNAK RECON        | RECON                  | 0             | <b>.</b>                | INTERRUPT                   |
| 10      | 70             | 90                  | 05                  | Z     | 8                   | 20                     | 5             | 8                       | COMMAND                     |
| 05      | RDDATA         | AUTO-<br>INC        | 0                   | 0     | 0                   | A10                    | A9            | 88                      | ADDRESS<br>PTR HIGH         |
| 03      | A7             | A6                  | A5                  | *     | A3                  | <b>A</b> 2             | P4            | PΟ                      | ADDRESS<br>PTR LOW          |
| 8       | <b>D</b> 7     | 8                   | 90                  | 2     | 23                  | 22                     | 2             | 8                       | DATA                        |
| 02      | 0              | 0                   | 0                   | 0     | 0                   | 0                      | 0             | 0                       | RESERVED                    |
| 80      | RESET          | COHEN               | YEN                 | E     | ET2                 | BACK-<br>PLANE         | SUB-          | SUB-<br>AD0             | CONFIG-<br>URATION          |
| 20      | /70IT<br>/70IN | /9CIN<br>/9CIN<br>0 | /SOIT<br>NIDS/<br>0 | NID4/ | TID3/<br>NID3/<br>0 | TID2/<br>NID2/<br>CKP2 | NID1/<br>CKP1 | TIDO/<br>NIDO/<br>ARBSL | TENTID/<br>NODEID/<br>SETUP |

provide the user with useful information about the network. The Node ID Register defaults to he value 0000 0000 upon hardware reset only.

#### Status Register

read-only register. All of the bits, except for bits 5 and 6, are software compatible with previous SMC ARCNET devices. In previous SMC ARCNET devices the Extended Timeout status was provided in bits 5 and 6 of the COM90C66, and the COM90C165, these bits Register. The Status Register contents are for the definition of the Status Register during The COM20020 Status Register is an 8-bit exist in and are controlled by the Configuration defined as in Table 4, but are defined differently Please refer to the Command Chaining section Register defaults to the value 1XX1 0001 upon during the Command Chaining operation. Status Register. In the COM20020, Command Chaining operation. either hardware or software reset.

### Diagnostic Status Register

The Diagnostic Status Register contains six the network or node operation. Various combinations of these bits and the TXEN bit of the Configuration Register represent different All of these bits, except the Excessive NAcK bit, are reset to logic "O" upon software or hardware reset. The EXCNAK bit is read-only bits which help the user troubleshoot reading the Diagnostic Status Register or upon reset by the "POR Clear Flags" command, upon Diagnostic Status Register defaults to the value 0000 00XX upon either hardware or software a high level on the TA bit of the Status Register, or upon software or hardware reset. situations.

#### Command Register

register. Any combinations of written data Execution of commands are initiated by performing microcontroller writes to this other than those listed in Table 6 are not permitted and may result in incorrect chip and/or network operation.

### Address Pointer Registers

writing to the Low Register because writing to These read/write registers are each 8-bits wide New pointer addresses should be written by first writing to the High Register and then contents of the Address Pointer High and Low and are used for addressing the internal RAM. Registers are undefined upon hardware reset. the Low Register loads the address.

### Configuration Register

The Configuration Register is a read/write register which is used to configure the different modes of the COM20020. The Configuration Register defaults to the value 0001 1000 upon hardware reset only.

#### Setup Register

accordingly (see the bit definitions of the independently. The data rate may be slowed to 312.5Kbps and/or the arbitration speed may be The Setup Register is a read/write 8-bit register accessed when the Sub Address Bits are set up Configuration Register). The Setup Register allows the user to change the network speed (data rate) or the arbitration speed slowed by a factor of two. The Setup Register defaults to the value 0000 0000 upon hardware eset only.

Ctotue Radietar Table A

|     |                                        | ř      | Table 4 - Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|----------------------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIT | BIT NAME                               | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7   | Receiver<br>Inhibited                  | ₩,     | This bit, if high, indicates that the receiver is not enabled because either an "Enable Receive to Page frun" command was never issued, or a packet has been deposited into the RAM buffer page frun as specified by the last "Enable Receive to Page frun" command. No messages will be received until this command is issued, and once the message has been received, the RI bit is set, thereby inhibiting the receiver. The RI bit is cleared by issuing an "Enable Receive to Page frun" command. This bit, when set, will cause an interrupt if the corresponding bit of the Interrupt Mask Register (IMR) is also set. |
| 6,5 | (Reserved)                             |        | These bits are undefined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4   | Power On Reset                         | POR    | This bit, if high, indicates that the COM20020 has been reset by either a software reset, a hardware reset, or writing 00H to the Node ID Register. The POR bit is cleared by the "Clear Flags" command.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3   | Test                                   | TEST   | This bit is intended for test and diagnostic purposes. It is a logic "O" under normal operating conditions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2   | Reconfiguration                        | RECON  | This bit, if high, indicates that the Line Idle Timer has timed out because the RXIN pin was idle for 82µS. The RECON bit is cleared during a "Clear Flags" command. This bit, when set, will cause an interrupt if the corresponding bit in the IMR is also set. The interrupt service routine should consist of examing the MYRECON bit of the Diagnostic Status Register to determine whether there are consecutive reconfigurations caused by this node.                                                                                                                                                                  |
| 1   | Transmitter<br>Message<br>Acknowledged | ТМА    | This bit, if high, indicates that the packet transmitted as a result of an "Enable Transmit from Page fnn" command has been acknowledged. This bit should only be considered valid after the TA bit (bit 0) is set. Broadcast messages are never acknowledged. The TMA bit is cleared by issuing the "Enable Transmit from Page fnn" command.                                                                                                                                                                                                                                                                                 |
| 0   | Transmitter<br>Available               | TA     | This bit, if high, indicates that the transmitter is available for transmitting. This bit is set at the conclusion of an "Enable Transmit from Page fun" command or upon execution of a "Disable Transmitter" command. The TA bit is cleared by issuing the "Enable Transmit from Page fun" command after the node next receives the token. This bit, when set, will cause an interrupt if the corresponding bit in the IMR is also set.                                                                                                                                                                                      |

2

A COLOR OF THE COL

| BIT NAME | SYMBOL       | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
|----------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|          | MY-<br>RECON | This bit, if high, indicates that a past reconfiguration was caused by this node. It is set when the Lost Token Timer times out, and is typically read following an interrupt caused by RECON. Refer to the improved Diagnostics section for further detail.                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Ò |
|          | DUPID        | This bit, if high, indicates that the value in the Duplicate ID Register matches both Destination ID characters of the token and a response to this token has occurred. The EOT character and the trailing zero's are also verified. A logic "1" on this bit indicates a duplicate Node ID, thus the user should write a new value into the Node ID Register. This bit is only useful for duplicate ID detection when the device is off line, that is, when the transmitter is off. When the device is on line it will be set every time the device gets the token. This bit is reset automatically upon reading the Diagnostic Status Register. Refer to the Improved Diagnostics section for further detail. |   |
| E   F    | RCVACT       | This bit, if high, indicates that data activity (logic "1") was detected on the RXIN pin of the device. Refer to the Improved Diagnostics section for further detail.  This bit, if high, indicates that a token has been seen on the network, sent by a node other than this one. Refer to the Improved Diagnostic section for further detail.                                                                                                                                                                                                                                                                                                                                                                |   |
| w        | EXCNAK       | This bit, if high, indicates that 128 Negative Acknowledgements have occurred in response to the Free Buffer Enquiry. This bit is cleared upon the "POR Clear Flags" command or upon a high level on the TA bit of the Status Register. Reading the Diagnostic Status Register does not clear this bit. This bit, when set, will cause an interrupt if the corresponding bit in the IMR is also set. Refer to the Improved Diagnostics section for further detail.                                                                                                                                                                                                                                             |   |
| F        | TENTID       | This bit, if high, indicates that a response to a token whose DID matches the value in the Tentative ID Register has occurred. In addition, the EOT character is checked. The second DID and the trailing zero's are not checked. Since each node sees every token passed around the network, this feature can be used with the device on-line in order to build and update a network map. Refer to the Improved Diagnostics section for further detail.                                                                                                                                                                                                                                                       |   |
| 1 1      |              | These bits are undefined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |

|           |                                     | Table 6 - Command Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA      | COMMAND                             | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0000 0000 | Clear<br>Transmit<br>Interrupt      | This command is used only in the Command Chaining operation. Please refer to the Command Chaining section for definition of this command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0000 0001 | Disable<br>Transmitter              | This command will cancel any pending transmit command (transmission that has not yet started) and will set the TA (Transmitter Available) status bit to logic "1" when the COM20020 next receives the token.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0000 0010 | Disable<br>Receiver                 | This command will cancel any pending receive command. If the COM20020 is not yet receiving a packet, the RI (Receiver Inhibited) bit will be set to logic "1" the next time the token is received. If packet reception is already underway, reception will run to its normal conclusion.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| bofn n100 | Enable<br>Receive to<br>Page fnn    | This command allows the COM20020 to receive data packets into RAM buffer page fnn and resets the RI status bit to logic "0". The values placed in the "nn" bits indicate the page that the data will be received into (page 0, 1, 2, or 3). If the value of "f" is a logic "1", an offset of 256 bytes will be added to that page specified in "nn", allowing a finer resolution of the buffer. Refer to the Selecting RAM Page Size section for further detail. If the value of "b" is logic "1", the device will also receive broadcasts (transmissions to ID zero). The RI status bit is set to logic "1" upon successful reception of a message.                                                                                                                          |
| 00fn n011 | Enable<br>Transmit from<br>Page fnn | This command prepares the COM20020 to begin a transmit sequence from RAM buffer page fun the next time it receives the token. The values of the "nn" bits indicate which page to transmit from (0, 1, 2, or 3). If "I' is logic "1", an offset of 256 bytes is added to that page specified in "nn", allowing a finer resolution of the buffer. Refer to the Selecting RAM Page Size section for further detail. When this command is loaded, the TA and TMA bits are reset to logic "0". The TA bit is set to logic "1" upon completion of the transmit sequence. The TMA bit will have been set by this time if the device has received an ACK from the destination node. The ACK is strictly hardware level, sent by the receiving node before its microcontroller is even |
|           |                                     | aware of message reception. Refer to Figure 1 for details of the transmit sequence and its relation to the TA and TMA status bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 6 - Command Register

| DESCRIPTION | This command defines the maximum length of packets that may be handled by the device. If "c" is a logic "1", the device handles both long and short packets. If "c" is a logic "0", the device handles only short packets. | This command resets certain status bits of the COM20020. A logic "1" on "p" resets the POR status bit and the EXCNAK Diagnostic status bit. A logic "1" on "r" resets the RECON status bit. | This command is used only in the Command Chaining operation. Please refer to the Command Chaining section for definition of this command. |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| COMMAND     | Define<br>Configuration                                                                                                                                                                                                    | Clear Flags                                                                                                                                                                                 | Clear<br>Receive<br>Interrupt                                                                                                             |
| DATA        | 0000 c101 Define                                                                                                                                                                                                           | 000r p110 Clear Flags                                                                                                                                                                       | 0000 1000 Clear<br>Recei                                                                                                                  |

Table 7 - Address Pointer High Register

| DESCRIPTION | This bit tells the COM20020 whether the following access will be a read or write. A logic "1" prepares the device for a read, a logic "0" prepares it for a write. | This bit controls whether the address pointer will increment automatically. A logic "1" on this bit allows automatic increment of the pointer after each access, while a logic "0" disables this function. Please refer to the Sequential Access Memory section for further detail. | These bits are undefined. | These bits hold the upper three address bits which provide addresses to RAM. |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------------------------------------|
| SYMBOL      | RDDATA                                                                                                                                                             | AUTOINC                                                                                                                                                                                                                                                                             |                           | A10-A8                                                                       |
| BIT NAME    | Read Data                                                                                                                                                          | Auto Increment                                                                                                                                                                                                                                                                      | (reserved)                | 2-0 Address 10-8                                                             |
| BIT         | 7                                                                                                                                                                  | ဖ                                                                                                                                                                                                                                                                                   | 5-3                       | 2-0                                                                          |

Table 8 - Address Pointer Low Register

|             | rovide                                                 |                       |
|-------------|--------------------------------------------------------|-----------------------|
| DESCRIPTION | These bits hold the lower 8 address bits which provide | the addresses to RAM. |
| SYMBOL      | A7-A0                                                  |                       |
| BIT NAME    | Address 7-0                                            |                       |
| BIT         | 7-0                                                    |                       |

Table 9 - Configuration Register

|     |                            | Table 9        | Table 9 - Configuration Register                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|----------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIT | BIT NAME                   | SYMBOL         | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7   | Reset                      | RESET          | A software reset of the COM20020 is executed by writing a logic "1" to this bit. A software reset does not reset the microcontroller interface mode, nor does it affect the Configuration Register. The only registers that the software reset affect are, the Status Register, the Interrupt Mask Register, and the Diagnostic Status Register. This bit must be brought back to logic "0" to release the reset.                          |
| ω   | Command<br>Chaining Enable | CCHEN          | This bit, if high, enables the Command Chaining operation of the device. Please refer to the Command Chaining section for further details. A low level on this bit ensures software compatibility with previous SMC ARCNET devices.                                                                                                                                                                                                        |
| ഥ   | Transmit Enable            | TXEN           | When low, this bit disables transmissions by keeping PULSE1, PULSE2 if in non-Backplane Mode, and TXENABLE inactive. When high, it enables the above signals to be activated during transmissions. This bit signals low upon reset. This bit is typically enabled once the Node ID is determined, and never disabled during normal operation. Please refer to the Improved Diagnostics section for details on evaluating network activity. |
| ٤,4 | Extended Timeout 1,2       | ET1, ET2       | These bits allow the network to operate over longer distances than the default 4 miles by controlling the Response, Idle, and Reconfiguration Times. All nodes should be configured with the same timeout values for proper network operation. The bit combinations follow:                                                                                                                                                                |
|     |                            |                | Response Idle Reconfig<br>Time Time Time<br>ET2 ET1 ( <u>US</u> ) ( <u>IMS</u> )                                                                                                                                                                                                                                                                                                                                                           |
|     |                            |                | 0 0 1193.6 1312 1680<br>0 1 596.8 656 1680<br>1 0 298.4 328 1680<br>1 1 74.7 82 840                                                                                                                                                                                                                                                                                                                                                        |
| 7   | Backplane                  | BACK-<br>PLANE | A logic "1" on this bit puts the device into Backplane Mode signalling which is used for Open Drain and Differential Driver interfaces.                                                                                                                                                                                                                                                                                                    |

Table 9 - Configuration Register

|             |                                                                                                     | <b>&gt;</b>            |                  |             |           |             |
|-------------|-----------------------------------------------------------------------------------------------------|------------------------|------------------|-------------|-----------|-------------|
| DESCRIPTION | These bits determine which register at address 07 may be accessed. The combinations are as follows: | SUBAD1 SUBADQ Register | 0 0 Tentative ID | 0 1 Node ID | 1 0 Setup | 1 Undefined |
| SYMBOL      | SUBAD<br>1,0                                                                                        |                        |                  |             |           |             |
| BIT NAME    | 1,0 Sub Address 1,0 SUBAD 1,0                                                                       |                        |                  |             |           |             |
| ВІТ         | 1,0                                                                                                 |                        |                  |             |           |             |

Table 10 - Setup Register

| N           |                           | These bits determine the network speed. Note that slowing the network speed does not slow the synchronous arbiter. The combinations are as follows when a 20MHz crystal is used: | Network Speed | 2.5Mbps<br>1.25Mbps<br>625Kbps | This bit, if high, divides the arbitration clock by 2, thus slowing arbitration by a factor of 2. Slowing the arbiter lengthens the cycle time to memory, but the access time remains the same. This bit defaults to a logic "0". |
|-------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DESCRIPTION | undefined.                | These bits determine the netwo slowing the network speed synchronous arbiter. The combi when a 20MHz crystal is used:                                                            | CLKPRESC1     | 0-0,                           | , divides the arbiti<br>ation by a factor<br>ns the cycle time<br>mains the same.                                                                                                                                                 |
|             | These bits are undefined. |                                                                                                                                                                                  | CLKPRESC2     | 00                             | This bit, if high slowing arbitra arbiter lengthe access time re logic "0".                                                                                                                                                       |
| SYMBOL      |                           | CLK-PRESC<br>2,1                                                                                                                                                                 |               |                                | SLOW-<br>ARB                                                                                                                                                                                                                      |
| BIT NAME    | (reserved)                | Clock Prescaler<br>2,1                                                                                                                                                           |               |                                | Arbitration<br>Slow                                                                                                                                                                                                               |
| ВП          | 7-3                       | 2,1                                                                                                                                                                              |               |                                | 0                                                                                                                                                                                                                                 |

#### INTERNAL RAM

The integration of the 2K x 8 RAM in the COM20020 represents significant real estate savings. The most obvious benefit is the 24-pin package in which the device is now placed (a direct result of the integration of RAM). In addition, the PC board is now free of the cumbersome external RAM, external latch, and multiplexed address/data bus and control

functions which were necessary to interface to the RAM.

The integration of RAM represents significant cost savings because it isolates the system designer from the changing costs of external RAM and it minimizes reliability problems, assembly time and costs, and layout complexity.



27

and the state of t

### Sequential Access Memory

location. If the Auto Increment bit is set to by the microcontroller. This process is RAM. Refer to Figure 6 for an illustration of the based scheme. Rather than interfering with from the microcontroller via the 8-bit data writing the corresponding address into the Address Pointer High and Low Registers (offsets 02H and 03H). Note that the High Register should be written first, followed by the Low Register, because writing to the Low Register oads the address. At this point the device corresponding data into the data register. The microcontroller then reads the data register (offset O4H) to obtain the data at the specified logic "1", the device will automatically increment the address and place the next byte of data into the data register, again to be read continued until the entire packet is read out of system memory, the internal RAM is indirectly accessed through the Address High and Low Pointer Registers. The data is channeled to and register. For example: a packet in the internal RAM buffer is read by the microcontroller by accesses that location and places the The internal RAM is accessed via a pointer-Sequential Access operation.

pointer must first be written with the starting address. The pointer may be read at any time pointer value before going into a subroutine. At When switching between reads and writes, the least one cycle time should separate the pointer to allow the microcontroller to save the present being loaded and the first read (see timing parameters).

#### Access Speed

Arbitration to the buffer does not slow down the cycle because the pointer based access method allows data to be prefetched from The COM20020 is able to accommodate very fast access cycles to its registers and buffers. memory and stored in a temporary register.

Likewise, data to be written is stored in the temporary register and then written to memory.

time, the arbitration clock may be slowed down by setting bit 0 of the Setup Register equal to logic "1". Since the Slow Arbitration feature For systems which do not require quick access divides the input clock by two, the duty cycle of the input clock may be relaxed.

### SOFTWARE INTERFACE

in the Internal Registers section. The software llow for accessing the data buffer is based on various registers. These actions are described The microcontroller interfaces to the COM20020 via software by accessing the The basic the Sequential Access scheme. sequence is as follows:

- Disable Interrupts Write to Pointer Register High (specifying Auto-Increment mode.)
  - Write to Pointer Register Low (this loads the address.)
    - Enable Interrupts
- Read or write the Data Register (repeat as many times as necessary to empty or fill the buffer.)
- The pointer may now be read to determine now many transfers were completed.

The software flow for controlling the Configuration, Node ID and Tentative ID registers is generally limited to the initialization sequence and the maintenance of the network

tie these actions together is discussed as follows. to know how the internal RAM buffer is properly set up. The sequence of events that Additionally, it is necessary to understand the details of how the other Internal Registers are used in the transmit and receive sequences and

### Selecting RAM Page Size

During normal operation, the 2K x 8 of RAM is divided into four pages of 512 bytes each. The page to be used is specified in the "Enable Transmit (Receive) from \*(to) Page fnn\* command, where "nn" specifies page 0, 1, 2, or 3. This allows the user to have constant control over the allocation of RAM. When the Offset bit "f" (bit 5 of the "Enable command word) is set to logic "1", an offset of 256 bytes is added to the page specified. For example: to transmit from the second half of page 0, the command "Enable Transmit from Page fnn" (fnn = 100 in this case) is issued by writing 0010 0011 to the Command Register. This allows a finer resolution of the buffer pages without affecting software compatibility. This frequently use packet sizes of 256 bytes or ess, especially for microcontroller systems with portions of the buffer pages which are not allocated for current transmit or receive packets may be used as temporary storage for previous network data, packets to be sent later, or as extra memory for the system, which may be scheme is useful for applications which The remaining Fransmit (Receive) from (to) Page fnn" imited memory capacity. indirectly accessed.

will be. In this case, the transmit pages may be made 256 bytes long, leaving at least 512 bytes free at any given time. Even if the 512 bytes is still guaranteed to be free because If the device is configured to handle both long command), then receive pages should always be 512 bytes long because the user never knows what the length of the receive packet Command Chaining only requires two pages for transmit and two for receive (in this case, two 256 byte pages for transmit and two 512 byte Pease note that it is the responsibility of Command Chaining operation is being used, software to reserve 512 bytes for each receive and short packets (see "Define Configuration" pages for receive, leaving 512 bytes free).

page if the device is configured to handle long packets. The COM20020 does not check page boundaries during reception.

packets, then both transmit and receive pages may be allocated as 256 bytes long, freeing at If the device is configured to handle only short least 1KByte at any given time. Even if the Command Chaining operation is being used, 1KByte is still guaranteed to be free because Command Chaining only requires two pages for transmit and two for receive (in this case, a total of four 256 byte pages, leaving 1K free). The general rule which may be applied to determine where in RAM a page begins is as

Address =  $(\ln x 512) + (f \times 256)$ 

### Transmit Sequence

buffer address 2 contains a zero or non-zero value. The format of the buffer is shown in COM20020 interprets the packet as either a selects a 256 or 512 byte segment of the RAM buffer and writes into it. The appropriate buffer command. When long packets are enabled, the ong or short packet, depending on whether the Figure 7. Address 0 contains the Source Identifier (SID); Address 1 contains the long packets, the value O, indicating that it is node to reply to the transmitting node. The During a transmit sequence, the microcontroller Destination Identifier (DID); Address 2 (COUNT) contains, for short packets, the value 256-N, where N represents the message length, or for Address 3 (COUNT) would contain the value 512-N, where N represents the message length. The SID in Address 0 is used by the receiving COM20020 puts the local ID in this location, therefore it is not necessary to write into this size is specified in the "Define Configuration" indeed a long packet. In the latter case,

28

The second his will be the control of the control of the best of the control of t

8051

unsuccessful transmission occurs when the

responds to the packet with an ACK.

receiving node does not respond to the packet.

transmission occurs when the receiving node

LONG PACKET **COUNT** = 512-N DATA BYTE N-1 DATA BYTE 2 DATA BYTE N DATA BYTE 1 NOT USED FORMAT 음 S 0 ADDRESS COUNT 511 C **COUNT** = 256-N SHORT PACKET DATA BYTE N-1 DATA BYTE N DATA BYTE 1 DATA BYTE 2 FORMAT NOT USED NOT USED 吕 믕 ADDRESS COUNT 255 51

(DID = 0 FOR BROADCASTS) N = DATA PACKET LENGTH DID = DESTINATION ID SID = SOURCE ID

bytes. A minimum value of 257 exists on a sent, the user must add dummy bytes to the packet (00's) in order to make the packet fit packet may contain between 257 and 508 data ong packet; packet lengths of 254, 255, or 256 bytes. If packets of these lengths must be Please note that a short packet may contain between 1 and 253 data bytes, while a long long packet so that the COUNT is expressablein eight bits. This leaves three exception packet lengths which do not fit into either a short or nto a long packet.

BUFFER ENQUIRY to the destination node in depending on the traffic on the network and the of the transmit command, which is flagged when TA becomes a logic "1", generates an interrupt. If the device is configured for the Command Chaining operation, please see the the transmit sequence. Once the TA bit becomes COM20020 automatically issues a FREE order to send the message. At this point, one indicating that a previous transmit command ocation of the token at the time the transmit command was issued. Typically, the conclusion Command Chaining section for further detail on a logic "1", the microcontroller issues the if the message is not a BROADCAST, the microcontroller awaits a logic "1" on the TA bit, Each time the message is loaded and a transmit command issued, it will take a variable amount of time before the message is transmitted, nas concluded and another may be issued. "Enable Transmit from Page fnn" command, which resets the TA and TMA bits to logic "O" the buffer is written into, of four possibilities may occur.

at the destination node, in which case it responds with an ACKnowledgement. At this point, the COM20020 fetches the data from the sequence. If a successful transmit sequence is Fransmit Buffer and performs the transmit to logic "1". If the packet was not transmitted The first possibility is if a free buffer is available completed, the TMA bit and the TA bit are set successfully, TMA will not be set. A successful

responds to the Free Buffer Enquiry with a when the RI bit of the destination node is a ogic "1". In this case, the token is passed on is again passed onto the next node. The Excessive NAK bit of the Diagnostic Status continuously receive a NAK as a response. The command. This causes the transmission to be abandoned and the TA bit to be set to a logic Please refer to the Improved Diagnostics section The second possibility is if the destination node Negative Acknowledgement. A NAK occurs The next time the transmitter receives the token, it will again transmit a FREE BUFFER ENQUIRY. If a NAK is again received, the token Register is used to prevent an endless loop of FBE's and NAK's. If no timeout existed, the transmitting node would continue issuing a Free Buffer Enquiry, even though it would EXCNAK bit generates an interrupt (if enabled) in order to tell the microcontroller to disable the from the transmitting node to the next node. transmitter via the "Disable Transmitter" "1" when the node next receives the token, while the TMA bit remains at a logic "O" or further detail on the EXCNAK bit. The third possibility which may occur after a destination node does not respond at all. In this REE BUFFER ENQUIRY is issued is if the case, the TA bit is set to a logic "1", while the TMA bit remains at a logic "0". The user should determine whether the node should try to reissue the transmit command.

response is received (some pattern other than ACK or NAK, such as noise). In this case, the token is not passed onto the next node, which causes the Lost Token Timer of the next node to time out, thus generating a network The fourth possibility is if a non-traditional econfiguration.

The second was a second of the second of the

3

FIGURE 7 - RAM BUFFER PACKET CONFIGURATION

receive circuitry has failed. These situations another software timeout which is greater than which occurs when all nodes transmit a The "Disable Transmitter" command may be used to cancel any pending transmit command when the COM20020 next receives the token. Normally, in an active network, this command will set the TA status bit to a logic "1" when If the "Disable Transmitter" command does not cause the TA bit to be set in the time it takes the token to make a round trip through the network, one of three situations exists. Either the node is disconnected from the network, or there are no other nodes on the network, or the external can be determined by either using the improved diagnostic features of the COM20020 or using the worst case time for a round trip token pass, maximum length message. the token is received.

#### Receive Sequence

becoming a logic "1", which indicates that a is set to logic "1". Otherwise, the alerted to the fact that the previous reception buffer. Again, the appropriate buffer size is command. Typically, the page which just received the data packet will be read by the microcontroller must periodically check the Status Register. Once the microcontroller is has concluded, it may issue the "Enable Receive to Page fnn" command, which resets the RI bit to logic "O" and selects a new page in the RAM A receive sequence begins with the RI status bit corresponding bit in the Interrupt Mask Register "Define Configuration" be interrupted if previous reception has concluded. microcontroller at this point. microcontroller will specified in the

Once the "Enable Receive to Page fun" command is issued, the microcontroller attends to other duties. There is no way of knowing how long the new reception will take, since another node may transmit a packet at any time. When another node does transmit a

without rearranging any bytes in the RAM buffer other than the SID and DID. Once the packet is received and stored correctly in the selected buffer, the COM20020 sets the RI bit to logic "1" to signal the microcontroller that (DID), and Address 2 contains, for short packets, the value 256-N, where N represents the message length, or for long packets, the packet. In the latter case, Address 3 contains message length. Note that on reception, the COM20020 deposits packets into the RAM buffer in the same format that the transmitting node arranges them, which allows for a message to be received and then retransmitted to this node, and if the "Define Configuration" command has enabled the reception of long packets, the COM20020 packet, depending on whether the content of he buffer location 2 is zero or non-zero. The format of the buffer is shown in Figure 7. Address 1 contains the Destination Identifier value 0, indicating that it is indeed a long the value 512-N, where N represents the interprets the packet as either a long or short Address 0 contains the Source Identifier (SID), the reception is complete. packet

### COMMAND CHAINING

The Command Chaining operation allows consecutive transmissions and receptions to occur without host intervention. Through the use of a dual two-level FIFO, commands to be transmitted and received, as well as the status bits, are pipelined.

In order for the COM20020 to be compatible with previous SMC ARCNET devices, the device defaults to the non-chaining mode. In order to take advantage of the Command Chaining operation, the Command Chaining Mode must be enabled via a logic "1" on bit 6 of the Configuration Register.

In Command Chaining, the Status Register appears as in Figure 8.



FIGURE 8 - COMMAND CHAINING STATUS REGISTER

The following is a list of Command Chaining guidelines for the software programmer to follow. Further detail can be found in the Transmit Command Chaining and Receive Command Chaining sections.

- The device is designed such that the interrupt service routine latency does not affect performance.
- Up to two outstanding transmissions and two outstanding receptions can be pending at any given time. The commands may be given in any order.
- Up to two outstanding transmit interrupts and two outstanding receive interrupts are stored by the device, along with their respective status bits.
- The Interrupt Mask bits act on TTA (Rising Transition on Transmitter Available) for transmit operations and TRI (Rising Transition of Receiver Inhibited) for receive operations. TTA is set upon completion of a packet transmission only. TRI is set upon completion of a packet reception only. Typically there is no need to mask the TTA and TRI bits after cleaning the interrupt.
- The traditional TA and RI bits are still available to reflect the present status of the device.

### Transmit Command Chaining

When the processor issues the first "Enable Transmit to Page fun" command, the COM20020 responds in the usual manner by resetting the TA and TMA bits to prepare for the transmission from the specified page. The TA bit can be used to see if there is currently a transmission pending, but the TA bit is really meant to be used in the non-chaining mode only. The TTA bits provide the relevant information for the device in the Command Chaining mode.

In the Command Chaining Mode, at any time after the first command is issued, the processor can issue a second "Enable Transmit from Page fron" command. The COM20020 stores the fact that the second transmit command was issued, along with the page number.

After the first transmission is completed, the COM20020 updates the Status Register by setting the TTA bit, which generates an interrupt. The interrupt service routine should read the Status Register. At this point, the TTA bit will be found to be a logic "1" and the TMA (Transmit Message Acknowledge) bit will tell the processor whether the transmission was successful. After reading the Status Register, the "Clear Transmit Interrupt" command is issued, thus resetting the TTA bit and clearing the interrupt. Note that only the "Clear

The second secon

Fransmit Interrupt" command will clear the TTA Interrupt command is issued. Note that the interrupt will remain active until the command is COM20020 guarantees a minimum of 200nS away because the status of the transmit operation is double buffered in order to retain the results of the first transmission for analysis by the processor. This information will remain until the first interrupt is acknowledged. The interrupts. The TMA bit is also double buffered to reflect whether the appropriate transmission was a success. The TMA bit should only be however, to clear the bit or the interrupt right issued, and the second interrupt will not occur interrupt inactive time interval between considered valid after the corresponding TTA bit has been set to a logic "1". The TMA bit never bit and the interrupt. It is not necessary, in the Status Register until the "Clear Transmit causes an interrupt.

When the token is received again, the second transmission will be automatically initiated after the first is completed by using the stored "Enable Transmit from Page fnn" command. The operation is as if a new "Enable Transmit from Page fnn" command has just been issued. After the first Transmit status bits are cleared, the Status Register will again be updated with the results of the second transmission and a second interrupt resulting from the second transmission will occur. The COM20020 guarantees a minimum of 200ns interrupt inactive time interval before the following edge.

The Transmitter Available (TA) bit of the Interupt Mask Register now masks only the TTA bit of the Status Register, not the TA bit as in the non-chaining mode. Since the TTA bit is only set upon transmission of a packet (not by RESET), and since the TTA bit may easily be reset by issuing a "Clear Transmit Interrupt command, there is no need to use the TA bit of the Interrupt Mask Register to mask interrupts generated by the TTA bit of the Status Register.

In both the Command Chaining mode and the non-chaining mode, the "Disable Transmitter" command will cancel the oldest transmission. This permits canceling a packet destined for a node not ready to receive. If both packets should be canceled, two "Disable Transmitter" commands should be issued.

### Receive Command Chaining

Like the Transmit Command Chaining operation, the processor can issue two consecutive "Enable Receive from Page fnn" commands.

Register will be set to logic "1", causing an interrupt. Again, the interrupt need not be After the first packet is received into the first specified page, the TRI bit of the Status serviced immediately. Typically, the interrupt service routine will read the Status Register. At this point, the RI bit will be found to be a logic "1". After reading the Status Register, the "Clear Receive Interrupt" command should be ssued, thus resetting the TRI bit and clearing the interrupt. Note that only the "Clear Receive nterrupt" command will clear the TRI bit and the interrupt. It is not necessary, however, to clear the bit or the interrupt right away because the status of the receive operation is double buffered in order to retain the results of the first therefore the information will remain in the Status Register until the "Clear Receive interrupt" command is issued. Note that the Receive Interrupt" command is issued, and the nterrupt will remain active until the "Clear second interrupt will be stored until the first reception for analysis by the processor, nterrupt is acknowledged. A minimum of 200nS interrupt inactive time interval between nterrupts is guaranteed. The second reception will occur as soon as a second packet is sent to the node, as long as the second "Enable Receive to Page fnn" command was issued. The operation is as if a

new "Enable Receive to Page fun" command has just been issued. After the first Receive status bits are cleared, the Status Register will again be updated with the results of the second reception and a second interrupt resulting from the second reception will occur.

In the COM20020, the Receive Inhibit (RI) bit of the Interrupt Mask Register now masks only the TRI bit of the Status Register, not the RI bit as in the non-chaining mode. Since the TRI bit is only set upon reception of a packet (not by RESET), and since the TRI bit may easily be reset by issuing a "Clear Receive Interrupt" command, there is no need to use the RI bit of the Interrupt Mask Register to mask interrupts generated by the TRI bit of the Status Register. In both the Command Chaining mode and the non-chaining mode, the "Disable Receiver" command will cancel the oldest reception, unless the reception has already begun. If both receptions should be canceled, two "Disable Receiver" commands should be issued.

#### RESET DETAILS

### Internal Reset Logic

The COM20020 includes special reset circuitry to guarantee smooth operation during reset. Special care is taken to assure proper operation in a variety of systems and modes of operation. The COM20020 contains digital filter circuitry and a Schmitt Trigger on the RESET IN signal to reject glitches in order to ensure fault-free operation.

The COM20020 supports two reset options; software and hardware reset. A software reset is generated when a logic "1" is written to bit 7 of the Configuration Register. The device remains in reset as long as this bit is set. The software reset does not affect the microcontroller interface modes determined

after hardware reset, nor does it affect the contents of the Address Pointer Registers, the Configuration Register, or the Setup Register. A hardware reset occurs when a low signal is asserted on the RESET IN input. The minimum reset pulse width is 120 nS (or 2T+20 nS for crystal frequencies other than 20MHz, where T = 1/f). This pulse width is used by the internal digital filter, which filters short glitches to allow only valid resets to occur.

Upon reset, the transmitter portion of the device is disabled and the internal registers assume those states outlined in the Internal Registers section.

After the RESET IN signal is removed the user may write to the internal registers. Since writing a non-zero value to the Node ID Register wakes up the COM20020 core, the Setup Register should be written before the Node ID Register. Once the Node ID Register is written to, the COM20020 reads the value and executes two write cycles to the RAM buffer. Address 0 is written with the data D1H and address 1 is written with the Node ID. The data pattern D1H was chosen arbitrarily, and is meant to provide assurance of proper nicrosequencer operation.

### NITIALIZATION SEQUENCE

When the COM20020 is powered on the internal registers may be written to. Since writing a non-zero value to the Node ID Register wakes up the core, the Setup Register should be written to before the Node ID Register. Until a non-zero value is placed into the NID Register, no microcode is executed, no tokens are passed by this node, and no reconfigurations are generated by this node. Once a non-zero value is placed in the register, the core wakes up, but the node will not attempt to join the network until the TX Enable bit of the Configuration positive is exert.

The second and the control of the co

Before setting the TX Enable bit, the software may make some determinations. The software may first observe the Receive Activity and the Token Seen bits of the Diagnostic Status Register to verify the health of the receiver and the network.

Next, the uniqueness of the Node ID value placed in the Node ID Register is determined. of the Diagnostic Status Register is set after a until it is ensured that the Node ID is unique. If this node ID already exists, the Duplicate ID bit maximum of 840mS (or 1680mS if the ET1 and ET2 bits are other than 1,1). To determine if another node on the network already has this ID, the COM20020 compares the value in the Node ID Register with the DID's of the token, and determines whether there is a response to the DUPID bit is cleared. The user may then attempt a new ID value, wait 840mS before point, the TX Enable bit may be set to allow the node to join the network. Once the node joins The TX Enable bit should still be a logic "O" checking the Duplicate ID bit, and repeat the process until a unique Node ID is found. At this it. Once the Diagnostic Status Register is read, the network, a reconfiguration occurs, as usual, thus setting the MYRECON bit of the Diagnostic Status Register. The Tentative ID Register may be used to build a network map of all the nodes on the network, even once the COM20020 has joined the network. Once a value is placed in the Tentative ID Register, the COM20020 looks for a response to a token whose DID matches the Tentative ID Register. The software can record this information and continue placing Tentative ID values into the register to continue building the network map. Note that a complete network map is only valid until nodes are added to or deleted from the network.

### IMPROVED DIAGNOSTICS

The COM20020 allows the user to better manage the operation of the network through

the use of the internal Diagnostic Status Register.

A high level on the My Reconfiguration (MYRECON) bit indicates that the Token Reception Time of this node expired, causing a reconfiguration by this node. After the Register interrupts the microcontroller, the interrupt service routine will typically read the MYRECON bit of the Diagnostic Status Register. Reading the Diagnostic Status Register. Reading the Diagnostic Status Register resets the MYRECON bit. Successive occurrences of a logic "1" on the MYRECON bit indicates that a problem exists with this node. At that point, the transmitter should be disabled so that the entire network is not held down while the node is being evaluated.

The Duplicate ID (DUPID) bit is used before the node joins the network to ensure that another node with the same ID does not exist on the network. Once it is determined that the ID in the Node ID Register is unique, the software should write a logic "1" to bit 5 of the Configuration Register to enable the basic transmit function. This allows the node to join the network.

The Receive Activity (RCVACT) bit of the Diagnostic Status Register will be set to a logic "1" whenever activity (logic "1") is detected on the RXIN pin.

The Token Seen (TOKEN) bit is set to a logic 11" whenever any token has been seen on the network (except those tokens transmitted by this node).

The RCVACT and TOKEN bits may help the user to troubleshoot the network or the node. If unusual events are occurring on the network, the user may find it valuable to use the TXEN bit of the Configuration Register to quality events. Different combinations of the RCVACT, TOKEN, and TXEN bits, as shown indicate different situations:

### Normal Results:

RCVACT = 1, TOKEN = 1, TXEN = 0. The node is not part of the network. The network is operating properly without this node.

RCVACT = 1, TOKEN = 1, TXEN = 1: The node sees receive activity and sees the token. The basic transmit function is enabled. Network and node are operating properly.

MYRECON=0, DUPID=0, RCVACT=1, TXEN=0, TOKEN=1: Single node network.

#### Abnormal Results:

RCVACT = 1, TOKEN = 0, TXEN = X: The node sees receive activity, but does not see the token. Either no other nodes exist on the network, some type of data corruption exists, the media driver is malfunctioning, the topology is set up incorrectly, there is noise on the network, or a reconfiguration is occurring.

RCVACT = 0, TOKEN = 0, TXEN = 1: No receive activity is seen and the basic transmit function is enabled. The transmitter and/or receiver are not functioning properly.

RCVACT = 0, TOKEN = 0, TXEN = 0. No receive activity and basic transmit function disabled. This node is not connected to the network.

The Excessive NAK (EXCNAK) bit is used to replace a timeout function traditionally implemented in software. This function is necessary to limit the number of times a sender issues a FBE to a node with no available buffer. When the destination node replies to 128 FBE's with 128 NAK's, the EXCNAK bit of the sender is set, generating an interrupt. At this point the software may abandon the transmission via the "Disable Transmitter" command. This sets the TA bit to logic "1" when the node next receives the token, to allow a different transmission to

The user may choose to wait for more NAK's before disabling the transmitter by taking advantage of the wraparound counter of the EXCNAK bit. When the EXCNAK bit goes high, indicating 128 NAK's, the "POR Clear Flags" command may be issued to reset the bit so that it will go high again after another count of 128. The software may count the number of times the EXCNAK bit goes high, and once the final count is reached, the "Disable Transmitter" command may be issued.

The Tentative ID bit allows the user to build a network map of those nodes existing on the network. This feature is useful because it minimizes the need for human intervention. When a value placed in the Tentative ID Register matches the Node ID of another node on the network, the TENTID bit is set, telling the software should periodically place values in the Tentative ID Register to maintain an updated network map.

#### OSCILLATOR

The COM20020 contains circuitry which, in conjunction with an external parallel resonant crystal or TTL clock, forms an oscillator.

If an external crystal is used, two capacitors are needed (one from each leg of the crystal to ground). No external resistor is required, since the COM20020 contains an internal resistor. The crystal must have an accuracy of 0.020% or better.

The XTAL2 side of the crystal may be loaded with a single 74HC-type buffer in order to generate a clock for other devices.

The user may attach an external TTL clock, rather than a crystal, to the XTAL1 signal. In this case, a 390Ω pull-up resistor is required on XTAL1, while XTAL2 should be left unconnected.

The content of the co

# OPERATIONAL DESCRIPTION

# MAXIMUM GUARANTEED RATINGS\*

\*Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the Absolute Maximum Ratings not be exceeded or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when the AC power is switched on or off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

# DC ELECTRICAL CHARACTERISTICS V<sub>00</sub> = 5.0V ± 10% COM20020: T<sub>4</sub> = 0°C to +70°C, COM20020 I: T<sub>4</sub> = -40°C to +85°C

|                                                                     | COMMENT   | TTL Levels                                               | TTL Levels                              |               | TTL Clock Input             |                              | Schmitt Trigger,<br>All Values at V <sub>00</sub> = 5V    |                                                                 |
|---------------------------------------------------------------------|-----------|----------------------------------------------------------|-----------------------------------------|---------------|-----------------------------|------------------------------|-----------------------------------------------------------|-----------------------------------------------------------------|
| ر<br>ر                                                              | UNIT      | >                                                        | >                                       |               | ۸                           | >                            | >                                                         | >                                                               |
| C to +8                                                             | MAX       | 8.0                                                      |                                         |               | 1.0                         |                              |                                                           |                                                                 |
| : I = -40                                                           | TYP       |                                                          |                                         |               |                             |                              | 1.8                                                       | 1.2                                                             |
| 120020                                                              | NIM       |                                                          | 2.0                                     |               |                             | 4.0                          |                                                           |                                                                 |
| +/9, co                                                             | SYMBOL    | V <sub>R1</sub>                                          | \<br>F#                                 |               | ۷ارء                        | V <sub>IH2</sub>             | нпу                                                       | \<br>¥                                                          |
| $COMZOUZO: I_A = 0.0 t0 + 10.0$ , $COMZOUZO: I_A = -40.0 t0 + 85.0$ | PARAMETER | Low Input Voltage 1 (All inputs except XTAL1, RESET, RD, | High Input Voltage 1 (All inputs except | WR, and RXIN) | Low Input Voltage 2 (XTAL1) | High Input Voltage 2 (XTAL1) | Low to High Threshold Input Voltage (RESET, RD, WR. RXIN) | High to Low Threshold<br>Input Voltage (RESET,<br>RD, WR, RXIN) |

| PARAMETER                                                            | SYMBOL           | MIN | ТҮР | MAX  | UNIT | COMMENT                                             |
|----------------------------------------------------------------------|------------------|-----|-----|------|------|-----------------------------------------------------|
| Low Output Voltage 1<br>(PULSE in Normal<br>Mode, PULSE2,<br>TXEN)   | Vol1             |     |     | 0.4  | >    | I <sub>SINK</sub> = 4mA                             |
| High Output Voltage 1<br>(PULSET in Normal<br>Mode, PULSEZ,<br>TXEN) | V <sub>OH1</sub> | 2.4 |     |      | >    | Isounce = -12mA                                     |
| Low Output Voltage 2 (DO-D7)                                         | V <sub>0L2</sub> |     |     | 4.0  | >    | I <sub>SINK</sub> = 16mA                            |
| High Output Voltage 2 (DO-D7)                                        | V <sub>OH2</sub> | 2.4 |     |      | >    | I <sub>sounce</sub> = -12mA                         |
| Low Output Voltage 3 (INTR)                                          | ۸٥٢ع             |     |     | 0.8  | >    | I <sub>SNX</sub> = 24mA                             |
| High Output Voltage 3 (INTR)                                         | V <sub>онз</sub> | 2.4 |     |      | >    | I <sub>sourα</sub> = -10mA                          |
| Low Output Voltage 4<br>(PULSET in Backplane<br>Mode)                | Vot4             |     |     | 0.5  | >    | I <sub>sink</sub> = 48mA<br>Open Drain Driver       |
| Dynamic V <sub>pp</sub> Supply<br>Current 1                          | looı             |     |     | 50   | mA   |                                                     |
| Input Pull-up Current<br>(PULSE1 in Backplane<br>Mode, A1, ADO-AD2,  | 4                |     | 30  | 95   | Νη   | V <sub>IN</sub> = 0.0V                              |
| Input Leakage Current (All inputs except A1,                         |                  |     |     | ± 10 | Α'n  | V <sub>SS</sub> < V <sub>IN</sub> < V <sub>DD</sub> |
| XTAL1, XTAL2)                                                        |                  |     |     |      |      |                                                     |

AMERICAN AND AND AND AND ADMINISTRATION OF THE PROPERTY OF THE

**CAPACITANCE** ( $T_A = 25^{\circ}C$ ;  $f_c = 1$ MHz;  $V_{DD} = 0$ V) Output and I/O pins capacitive load specified as follows:

| PARAMETER                               | SYMBOL | MIN |   | TYP MAX |    | UNIT COMMENTS                |
|-----------------------------------------|--------|-----|---|---------|----|------------------------------|
| Input Capacitance                       | ی      |     |   | 0.3     | Jd |                              |
| Output Capacitance 1                    | Court  |     |   | 45      | дd | Maximum                      |
| (All outputs except PULSE1 in BackPlane |        |     |   |         |    | Capacitive Load which can be |
| Mode)                                   |        |     |   |         |    | supported by each            |
| Output Capacitance 2                    | Courz  |     |   | 400     | Ā  | output.                      |
| (PULSE1, in BackPlane                   | -      |     | • |         |    |                              |
| Mode Only)                              |        |     |   |         |    |                              |

|                |                                         | 250 | 11 12 | - E       |
|----------------|-----------------------------------------|-----|-------|-----------|
| VALID DATA     |                                         |     |       | <b>85</b> |
| WALD Y         | 11 - 12 - 12 - 12 - 12 - 12 - 12 - 12 - |     | - ts  | 19        |
| ADO-AD2, D3-D7 | ୪                                       | ALE | S     | RIO       |
|                |                                         |     |       |           |

Outputs:

AC Measurements are taken at the following points:

Inputs:

2.0

0.8

20%

2.4 <del>1</del>. 0.47 2.0

0.87

20%

0.47

2.4 **1.**4∨

|            | Parameter                            | min        | max | units    |
|------------|--------------------------------------|------------|-----|----------|
| ₽          | Address Setup to ALE Low             | 30         |     | Su       |
| Ы          | Address Hold from ALE Low            | 9          |     | <u>ہ</u> |
| Ω          | CS Setup to ALE Low                  | 2          |     | ည        |
| 7          | CS Hold from ALE Low                 | 8          |     | ည        |
| ŧ          | ALE Low to DS Low                    | 15         |     | స్       |
| 9          | DS Low to Valid Data                 |            | 4   | స్       |
| 17         | DS High to Data High Impedance       | 0          | 8   | ည        |
| <b>6</b> 9 | Cycle Time (DS Low to Next Time Low) | 3.5T+10nS* |     | ည        |
| 6          | DIR Setup to DS Active               | 9          |     | ည        |
| 110        | DIR Hold from DS Inactive            | 5          |     | ন        |

Ex: t8 min is 185 nS if 20MHz crystal is used. T is identical to XTAL1 if SLOW ARB = 0, T is the Arbitration Clock Period.

T is twice XTAL1 period if SLOW ARB = 1

Outputs are measured at 2.0V min. for logic "1" and 0.8V max. for logic "0".

Inputs are driven at 2.4V for logic "1" and 0.4 V for logic "0".

Note 1: The Microcontroller typically accesses the COM20020 on every other cycle. Therefore, the cycle time specified in the microcontroller's datasheet should be doubled when considering back-to-back COM20020 cycles.

FIGURE 9 - MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; READ CYCLE

4

de anaderia de de de de de deservir de la composição de la composição de la composição de la composição de la



|      | Parameter                              | min        | max | units |
|------|----------------------------------------|------------|-----|-------|
| =    | Address Setup to ALE Low               | 08         |     | S.    |
| £ 52 | Address Hold from ALE Low              | 9 2        |     | ည     |
|      | CS Setup to ALE Low                    | 2          |     | ည     |
| 4    | CS Hold from ALE Low                   | 20         |     | ည     |
| ţ    | ALE Low to DS Low                      | 5          |     | ည     |
| 9    | Valid Data Setup to DS High            | 8          |     | ည     |
| 17   | Data Hold from DS High                 | 2          |     | ည     |
|      | Cycle Time (DS Low to Next Time Low)** | 3.5T+10nS* |     | ည     |
| đ    | DIR Setup to DS Active                 | 9          |     | ည     |
| 110  | DIR Hold from DS Inactive              | 5          |     | S     |

units

max

ᄪ

Parameter

Address Hold from ALE Low Address Setup to ALE Low

CS Setup to ALE Low
CS Hold from ALE Low

**= 3 2 4 4 4 4 5** 

17 1

Ţ,

9

Ħ

ţ

ξ

VALID DATA

ն

VALID

AD0-AD2, D3-D7

4

ಭ 1

> ALE 8

ဗြ

8 2 2 2 5

**48** 

3.5T+10nS\*

Cycle Time (RD Low to Next Time Low)

ALE Low to RD Low RD Low to Valid Data RD High to Data High Impedance

Ex: t8 min is 185 nS if 20MHz crystal is used.

T is the Arbitration Clock Period.

T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0,

C

\* T is the Arbitration Clock Period.

T is identical to XTAL1 if SLOW ARB = 0,

Ex: t8 min is 185 nS if 20MHz crystal is used. T is twice XTAL1 period if SLOW ARB = 1 The Microcontroller typically accesses the COM20020 on every other cycle. Therefore, the cycle time specified in the microcontroller's datasheet should be doubled when considering back-to-back COM20020 cycles. Note 1:

\*\* Note 2: Any cycle occurring after a write to Address Pointer Low Register requires a minimum of 3.5T + 10ns from the trailing edge of DS to the leading edge of the next DS. FIGURE 10 - MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; WRITE CYCLE

Note 1: The Microcontroller typically accesses the COM20020 on every other cycle. should be doubled when considering back-to-back COM20020 cycles. Therefore, the cycle time specified in the microcontroller's datasheet

FIGURE 9A - MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; READ CYCLE

<u> Abertak Mendelah dan dangan</u> dalah Malabat Medelah Sadak S

**£** 



| units     | ត ត ត ត ត ត ត ត                                                                                                                                                                                                           |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| шах       | 40<br>20                                                                                                                                                                                                                  |
|           | *30nS*                                                                                                                                                                                                                    |
| Parameter | Address Setup to RD Active Address Hold from RD Inactive CS Setup to RD Active CS Hold from RD Inactive CS Hold from RD Inactive Oycle Time (RD Low to Next Time Low) RD Low to Valid Data RD High to Data High impedance |
|           | 12224557                                                                                                                                                                                                                  |
|           |                                                                                                                                                                                                                           |

units

шaх

뒽

Parameter

Address Hold from ALE Low Address Setup to ALE Low

S Hold from ALE Low

CS Setup to ALE Low ALE Low to WR Low

耍

စ္

ŧ

12 4

t Ā

ALE

ဗြ

N R

VALID

S S S S S S S S S

8658585

3.5T+10nS\*

Cycle Time (WR Low to Next Time Low)\*\*

Valid Data Setup to WR High Data Hold from WR High

T is the Arbitration Clock Period.

Ex: t6 min is 185 nS if 20MHz crystal is used. T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0,

CS may become active after control becomes active, but the access time will now be 45nS measured from the leading edge of CS. \*

Note 1: The Microcontroller typically accesses the COM20020ary other cycle. should be doubled when considering back to back C020 cycles. Therefore, the cycle time specified in the microcontrollstasheet

FIGURE 11 - NON-MULTIPLEXED BUS, 80XX-LIKE CONTRCNALS; READ CYCLE FIGURE 10A - MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; WRITE CYCLE

Any cycle occurring after a write to Address Pointer Low Register requires a minimum of 3.5T+10ns from the trailing edge of  $\overline{\rm WR}$  to the leading edge of the next  $\overline{\rm WR}$ .

The Microcontroller typically accesses the COM20020 on every other cycle.

Ex: t8 min is 185 nS if 20MHz crystal is used. T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0.

\* T is the Arbitration Clock Period.

should be doubled when considering back-to-back COM20020 cycles.

\*\* Note 2:

Note 1:

Therefore, the cycle time specified in the microcontroller's datasheet

我一般的名词复写 有好人多有好好人

editional and the second of the second of



4

Ā

ಭ

•

4

9

ţ

뚭

20

ø.

9

D0-D7

VALID DATA

ß

VALID

F

A0-A2

શ

|   |                | Parameter                               | min        | max | units |
|---|----------------|-----------------------------------------|------------|-----|-------|
| _ | Ŧ              | Address Setup to WR Active              | 15         |     | Sn    |
|   | В              | Address Hold from WR Inactive           | 9          |     | S.    |
| _ | ಭ              | CS Setup to WR Active                   | ß          |     | ပူ    |
| _ | 4              | CS Hold from WR Inactive                | 0          |     | ပူ    |
|   | τī             | Cycle Time (WR Low to Next Time Low) ** | 3.5T+10ns* |     | ပ်    |
| _ | <b>1</b> 9     | Valid Data Setup to WR High             | 30**       |     | ပ်    |
|   | t <sub>2</sub> | Data Hold from WR High                  | 9          |     | ဖု    |
|   |                |                                         |            |     |       |

Ex: t6 min is 185 nS if 20MHz crystal is used. T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0, T is the Arbitration Clock Period.

\*CS may become active after control becomes active, but the data setup time will now be 30 nS measured from the later of CS falling or Valid Data available.

The Microcontroller typically accesses the COM20020 on every other cycle. Therefore, the cycle time specified in the microcontroller's datasheet should be doubled when considering back-to-back COM20020 cycles. Vote 1:

Any cycle occurring after a write to the Address Pointer Low Register requires a minimum of 3.5T+10ns from the trailing edge of  $\overline{WR}$  to the leading edge of the next  $\overline{WR}$ . Note 2:

FIGURE 12 - NON-MULTIPLEXED BUS, 80XX-LIKE CONTROL SIGNALS; WRITE CYCLE

47

units

max

텵

Parameter

Address Hold from DS Inactive

CS Setup to DS Active CS Hold from DS Inactive

け ひ な な な な な な な

Address Setup to DS Active

3.5T+10nS\*

Cycle Time (DS Low to Next Time Low)

DIR Hold from DS Active DIR Setup to DS Active

DS Low to Valid Data DS High to Data High Impedence

51 0 t

**48** 

FIGURE 11A - NON-MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; READ CYCLE

Note 1: The Microcontroller typically accesses the COM20020 on every other cycle.

CS may become active after control becomes active, but the

\*

Ex: t6 min is 185 nS if 20MHz crystal is used.

T is the Arbitration Clock Period.

T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0,

access time will now be 45nS measured from the leading

edge of CS.

should be doubled when considering back-to-back COM20020 cycles. Therefore, the cycle time specified in the microcontroller's datasheet



units స్

max

VALID DATA

ġ

9

4

Ø

띪

ဗြ

S

ß

VALID

F

A0-A2

**δδδδδδδδδ** 

Cycle Time (DS Low to Next Time Low)\*\*

Valid Data Setup to DS High

Data Hold from DS High

DIR Hold from DS Inactive

Address Hold from DS Inactive

S Hold from DS Inactive

S Setup to DS Active

DIR Setup to DS Active

こ なな なな む ひ ち む

Address Setup to DS Active

Parameter

D0-D7

5005 5

\* t1 = 2 x (crystal period) for clock frequencies other than 20 MHz.

\* t2,t7 = 8 x (crystal period) for clock frequencies other than 20 MHz.

This period applies to data of two consecutive one's.

\*\* t4: For clock frequencies other than 20 MHz, t4 = 18 x (crystal period) ± 50 nsec. \*\* t5: For clock frequencies other than 20 MHz, t5 =  $6 \times (crystal period) \pm 50 nsec.$ 

FIGURE 13 - NORMAL MODE TRANSMIT OR RECEIVE TIMING (These signals are to and from the hybrid)

<del>\$</del>

FIGURE 12A - NON-MULTIPLEXED BUS, 68XX-LIKE CONTROL SIGNALS; WRITE CYCLE

The Microcontroller typically accesses the COM20020 on every other cycle. Therefore, the cycle time specified in the microcontroller's datasheet

Note 1:

Note 2:

should be doubled when considering back-to-back COM20020 cycles. Any cycle occurring after a write to the Address Pointer Low Register requires a minimum of 3.51+10ns from the trailing edge of DS to the leading edge of the next DS.

\*\*CS may become active after control becomes active, but the data setup time will

Ex: t6 min is 185 nS if 20MHz crystal is used.

T is the Arbitration Clock Period.

T is twice XTAL1 period if SLOW ARB = 1 T is identical to XTAL1 if SLOW ARB = 0.

now be 30 nS measured from the later of CS falling or Valid Data available.





units

max

Ş

ᆵ

Parameter

PULSE2 High to TXEN Low PULSE1 Pulse Width

Ξ

휴

XX

0

**δ δ δ δ δ δ δ δ δ** 

\$ 6 <del>\$</del>

20

0

PULSE2 Low to PULSE1 Low

PULSE2 High Time

200\* 400\*

₩ 128

ಭ

ŭ

**4** 

± 50 10

PULSE1

XEN

(400 nS BIT TIME)

15 - t6

 19
 TXEN Low to first PULSE1 Low\*\*
 650
 750

 110
 RXIN Pulse Width
 10
 200\*

 111
 RXIN Period
 400\*
 400\*

 \*15,16
 2 x (crystal period) for clock frequencies other than 20 MHz.

(First rising edge on PULSE2 after Last Bit Time)

PULSE2 High to TXEN High

PULSE2 Period

ပည

20

0

<mark>ნ</mark> ნ

\* t2,t7,t10 = 4 x (crystal period) for clock frequencies other than 20 MHz. \* t3,t11 = 8 x (crystal period) for clock frequencies other than 20 MHz.

This period applies to data of two consecutive one's.

\*\* t9: For clock frequencies other than 20 MHz, t9 =  $14 \times$  (clock period)  $\pm$  50 nsec. FIGURE 14 - BACKPLANE MODE TRANSMIT OR RECEIVE TIMING

20

(These signals are to and from the differential driver or the cable)

A CONTROL OF THE PROPERTY OF T





Seating



### COM20020 - Revision & **ERRATA SHEET**

| PAGE   | SECTION/FIGURE/ENTRY                                                                | CCTION                                                                                                                                                                                                                                                             |
|--------|-------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10,11  | Figures 2,3                                                                         | The TXEN signal shougated with an I/O port line from the host microcor. The output of the gate should then be used theldisable the differential driver (see figure on nege).                                                                                       |
| 14     | Differential Driver<br>Configuration                                                | In the Differential Drionfiguration, a 1K pull-up resistor should be cord to the PULSE1 pin (see figure on next page).                                                                                                                                             |
| 17     | Tentative ID Register, Node<br>ID Register                                          | RAM should not be acd while building a network map or performing thecate Node ID algorithm.                                                                                                                                                                        |
| <br>22 | Table 5 - Diagnostic Status<br>Register<br>Duplicate ID Bit and<br>Tentative ID Bit | These bits may not be if a RAM access occurred during the Destinationatching process which the device undergoes in tto update these bits. To ensure validity of these RAM accesses should not occur during the Dupl Node ID algorithm or the Network Map algorithn |
| 22     | Table 5 - Diagnostic Status<br>Register<br>Receive Activity Bit                     | When polling the RecActivity bit, the software should allow at least 8setween polls.                                                                                                                                                                               |
| <br>22 | Table 5 - Diagnostic Status<br>Register<br>Tentative ID Bit                         | Each node sees all tobassed on the network by other nodes; a node dot see its own token pass. Therefore, a node buildnetwork map while on-line will be able to identify the next logical node on the network.                                                      |
| <br>28 | Sequential Access Memory                                                            | Reading the pointer res upon interrupting a read sequence will not alvreturn the actual pointer value. Therefore, the sequence should be non-interruptible. Alternatia pointer counter can be maintained in software                                               |
| 35-37  | Initialization Sequence,<br>Improved Diagnostics                                    | RAM should not be acd while building a network map or performing the sate Node ID algorithm.                                                                                                                                                                       |

(continued)

The second secon



identified on the part by the letter preceding the date code. Example: These corrections apply to Revision A of the COM20020. The revision is



applications consequently complete information sufficient for construction purposes is not necessarily give. The information has been ceretuity checked and is believed to be antirely reliable. However, no responsibility is essumed for inaccuracies. Furthermore, such information dose not convey to the purchaser of the semiconductor devices described enty licenses under the patent rights of SMC or others. SMC reserves the infight to make changes at any time in order to improve design and supply the best product possible. STANDARD MICROSYSTEMS CORPORATION •1991 STANDARD MICROSYSTEMS CORP. PRODUCTS DIVISION

Circuit diagrems utilizing SMC products are included as a means of illustrating typical

8/21/91